-
Notifications
You must be signed in to change notification settings - Fork 252
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Increase maximum -s value to 65507 #344
Conversation
The pull request is correct for IPv4. In general, an attempt could be made to differentiate between IPv4 and IPv6.
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the pull request. It still needs some work before it can be accepted.
- There is an existing off-by-one error in the size check and error message. Currently, that does not matter much, because the assumed IP header size of 40 bytes is bigger than the off-by-one error. With your corrected IPv4 minimum header size, the reported error wrongly states that the value must be less than 65507, but 65507 is OK with your pull request. Please adjust the error message to be correct, e.g., "…must not be larger than…".
- There is a test that checks the error message when a too large value is used with
-b
. That test fails with your pull request because the reported size limit changes. Please adjust that test, you can find it inci/test-03-forbidden.pl
. - The test mentioned above currently uses an ICMP payload size of 65509 which is two bytes above the (IPv4) maximum. While you are working on this code, could you also adjust this to use 65508?
Thanks in advance and best regards,
Erik
doc/fping.pod
Outdated
@@ -50,7 +50,7 @@ room for the data that B<fping> needs to do its work (sequence number, | |||
timestamp). The reported received data size includes the IP header (normally | |||
20 bytes) and ICMP header (8 bytes), so the minimum total size is 40 bytes. | |||
Default is 56, as in B<ping>. Maximum is the theoretical maximum IP datagram | |||
size (64K), though most systems limit this to a smaller, system-dependent | |||
size (65K), though most systems limit this to a smaller, system-dependent |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please drop this change. 64K is widely understood as 2^16 and thus nearly correct (off-by-one error, 2^16-1 for IPv4). Using 65K is further off, both interpretations 651000 and 651024.
src/fping.c
Outdated
@@ -134,8 +134,9 @@ extern int h_errno; | |||
|
|||
/*** Ping packet defines ***/ | |||
|
|||
#define MAX_IP_PACKET 65536 /* (theoretical) max IP packet size */ | |||
#define SIZE_IP_HDR 40 | |||
/* NOTE: IPv6 would allow more: 65527 (65575 - 40 - 8), but we don't do reverse PTR lookup */ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please drop this comment, I find it confusing.
The ICMPv6 payload for a normal RFC 8200 IPv6 packet could be (40+2^16-1-8) bytes, because IPv6 uses a payload length field that excludes the fixed header length of 40 bytes. The calculation in the comment does not show this clearly.
fping
does not use separate payload sizes for IPv4 and IPv6 targets. Thus it cannot easily allow different sizes. It could theoretically check if it uses IPv6 (e.g., option -6
is active), but this is not done.
I'd say that this comment would be better as an issue to allow larger payloads for ICMPv6, but I definitely do not like it as a code comment.
69535b8
to
f9fd6bc
Compare
OK, FYI (it's explained in the commit message) I use IPv4 because the limit is smaller than IPv6 ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, I'd say that is OK. I plan on merging this in its current form in a week, unless some objection emerges.
ci/test-03-forbidden.pl
Outdated
$cmd8->exit_is_num(1); | ||
$cmd8->stdout_is_eq(""); | ||
$cmd8->stderr_is_eq("fping: data size 65509 not valid, must be lower than 65488\n"); | ||
$cmd8->stderr_is_eq("fping: data size 65508 not valid, must be lower than 65507\n"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for adjusting the test according to the changed maximum size definition. That suffices, I can adjust the incorrect error message (an existing issue, not introduced by this pull request) myself.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I got that and fixed:
-$cmd8->stderr_is_eq("fping: data size 65508 not valid, must be lower than 65507\n");
+$cmd8->stderr_is_eq("fping: data size 65508 not valid, must not be larger than 65507\n");
44997a0
to
fcd9b7f
Compare
Thanks for adjusting the error message, too! This looks good, there is just a little nit left: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please adjust the commit message, because it has two problems that could lead to confusion in the future:
- The affected option is
-b
, not-s
. This is problematic becausefping
has both options-b
and-s
, but they do totally different things. Please correct this in the first line of the commit message. - Current
fping
does print an error message when sending fails. This includes specifying a too large payload size. Please remove the incorrect statement that it does not from the commit message.
Regarding the error message with an oversized payload:
$ git diff
diff --git a/src/fping.c b/src/fping.c
index 696a017..6933eee 100644
--- a/src/fping.c
+++ b/src/fping.c
@@ -135,7 +135,7 @@ extern int h_errno;
/*** Ping packet defines ***/
#define MAX_IP_PACKET 65536 /* (theoretical) max IP packet size */
-#define SIZE_IP_HDR 40
+#define SIZE_IP_HDR 0
#define SIZE_ICMP_HDR 8 /* from ip_icmp.h */
#define MAX_PING_DATA (MAX_IP_PACKET - SIZE_IP_HDR - SIZE_ICMP_HDR)
$ ./src/fping -b 65528 127.0.0.1
127.0.0.1: error while sending ping: Message too long
127.0.0.1 is unreachable
Correct definitions: maximum theoretical IPv4 packet size and minimum IPv4 header size (previously probably IPv6 size was used). Because fping does not know ahead whether address is IPv4 or IPv6 assume IPv4. Previously fping allowed only 65488, but real maximum for IPv4 on Linux is 65507 (IPv6 would allow 65527 follow the current approach and allow smaller value than reachable for IPv6). Update test affected by this change. While at this, test 65508 (one above the limit) instead of 65509. Signed-off-by: Petr Vorel <[email protected]>
Try this (with allowing more size:
It just fails on IPv4 with no explanation. That is the difference with ping with iputils, where I can set the higher value (which is working for IPv6). If there were meaningful message on IPv4 on size between 65527 and 65508, I would suggest to set higher payload 65527, as I'm going to set for iputils (iputils/iputils#550). |
The problem is nicely visible with these commands which show first working IPv4: first good -b 65488, before "fping: data size 65489 not valid, must be lower than 65488 i=65535 a='127.0.0.1'; while true; do
cmd="./src/fping -c1 -b $i $a"
echo "== $cmd =="
$cmd && break
i=$((i-1))
echo
done
== ./src/fping -c1 -b 65535 127.0.0.1 ==
./src/fping: data size 65535 not valid, must not be larger than 65527
...
== ./src/fping -c1 -b 65528 127.0.0.1 ==
./src/fping: data size 65528 not valid, must not be larger than 65527
== ./src/fping -c1 -b 65527 127.0.0.1 ==
127.0.0.1 : xmt/rcv/%loss = 1/0/100%
...
== ./src/fping -c1 -b 65508 127.0.0.1 ==
127.0.0.1 : xmt/rcv/%loss = 1/0/100%
== ./src/fping -c1 -b 65507 127.0.0.1 ==
127.0.0.1 : [0], 128 bytes, 0.088 ms (0.088 avg, 0% loss)
127.0.0.1 : xmt/rcv/%loss = 1/1/0%, min/avg/max = 0.088/0.088/0.088 But it works well on IPv6, although current versioin doesn't allow the highest size. i=65535 a='::1'; while true; do
cmd="./src/fping -c1 -b $i $a"
echo "== $cmd =="
$cmd && break
i=$((i-1))
echo
done
== ./src/fping -c1 -b 65535 ::1 ==
./src/fping: data size 65535 not valid, must not be larger than 65527
...
== ./src/fping -c1 -b 65528 ::1 ==
./src/fping: data size 65528 not valid, must not be larger than 65527
== ./src/fping -c1 -b 65527 ::1 ==
::1 : [0], 128 bytes, 0.129 ms (0.129 avg, 0% loss)
::1 : xmt/rcv/%loss = 1/1/0%, min/avg/max = 0.129/0.129/0.129 |
Thanks for adjusting the commit message! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, the commit message is OK now.
Thanks for the explanations, I now understand the issue regarding error messages. Using one of |
I suppose this could not easily be fixed, thus let's ignore this possibility. Thanks for merging and your time. |
Correct definitions: maximum theoretical IPv4 packet size and minimum IPv4 header size (previously probably IPv6 size was used).
Because fping does not know ahead whether address is IPv4 or IPv6 assume IPv4. Previously fping allowed only
65488
, but real maximum for IPv4 on Linux is65507
(IPv6 would allow65527
).